<script>
export default {
  components: {},
  data () {
    return {
      radio: 0,
      radio2: 0,
      radio3: 0,
      radio4: 0,
      radio5: 0,
      radio6: 0
    };
  },
  computed: {
    isButtonDisabled() {
      return this.radio === 0;
    },
    isButtonDisabled2() {
      return this.radio2 === 0;
    },
    isButtonDisabled3() {
      return this.radio3 === 0;
    },
    isButtonDisabled4() {
      return this.radio4 === 0;
    },
    isButtonDisabled5() {
      return this.radio5 === 0;
    },
    isButtonDisabled6() {
      return this.radio5 === 0;
    }
  },
  methods: {
    check(radio) {
      console.log(radio)
      if (radio === 3) {
        this.$message.success('恭喜你，答对啦！')
      } else {
        this.$message.error('很遗憾，答错啦！')
      }
    },
    check2(radio2) {
      console.log(radio2)
      if (radio2 === 3) {
        this.$message.success('恭喜你，答对啦！')
      } else {
        this.$message.error('很遗憾，答错啦！')
      }
    },
    check3(radio3) {
      console.log(radio3)
      if (radio3 === 3) {
        this.$message.success('恭喜你，答对啦！')
      } else {
        this.$message.error('很遗憾，答错啦！')
      }
    },
    check4(radio4) {
      console.log(radio4)
      if (radio4 === 3) {
        this.$message.success('恭喜你，答对啦！')
      } else {
        this.$message.error('很遗憾，答错啦！')
      }
    },
    check5(radio5) {
      console.log(radio5)
      if (radio5 === 3) {
        this.$message.success('恭喜你，答对啦！')
      } else {
        this.$message.error('很遗憾，答错啦！')
      }
    },
    check6(radio6) {
      console.log(radio6)
      if (radio6 === 3) {
        this.$message.success('恭喜你，答对啦！')
      } else {
        this.$message.error('很遗憾，答错啦！')
      }
    }
  }
}
</script>

<template>
  <div>
    <h1 align="center">1.6 密码学基础</h1>
    <el-divider></el-divider>
    <h3>1.6.1 密码学导论</h3>
    <b>知识点</b><br>
    <ul>
      <li style="margin-left: 2em;">密码体制</li>
      <li style="margin-left: 2em;">古典密码</li>
      <li style="margin-left: 2em;">密码安全性</li>
    </ul>
    <b>学习目标</b><br>
    <ul>
      <li style="margin-left: 2em;">掌握密码技术的基本思想</li>
      <li style="margin-left: 2em;">掌握密码体制的组成结构</li>
      <li style="margin-left: 2em;">熟悉置换、代替和代数等古典密码的编码方法</li>
      <li style="margin-left: 2em;">掌握密码体制的分类</li>
      <li style="margin-left: 2em;">掌握密码安全性的概念</li>
      <li style="margin-left: 2em;">了解密码在信息安全领域的实际应用</li>
    </ul>
    <b>密码学基本思想</b><br>
    <el-image
        style="width: 970px; height: 390px"
        :src="require('@/assets/img/img1.png')">
    </el-image>
    <br>
    密码学的定义密码学是构建和分析不同加密解密方法的科学，该科学实际上包含两个部分：
    <ul>
      <li style="margin-left: 2em;">密码使用学是构建功能更强大、更有效的新密码的加密解密方法的科学。</li>
      <li style="margin-left: 2em;">密码分析学则是发现已有加密法的弱点，以便不用密钥就能还原成明文的科学。</li>
    </ul>
    密码分析是确保密码体制安全的唯一方法，是密码学不可缺少的部分。密码学与通信有着密不可分的关系，往往还能决定着战争的胜负。
    <br><b>密码与信息安全</b>
    <ul>
      <li style="margin-left: 2em;">密码总会被破解</li>
      <li style="margin-left: 2em;">密码的算法总会被公开</li>
      <li style="margin-left: 2em;">弱密码比不加密更危险</li>
      <li style="margin-left: 2em;">密码只是信息安全的一部分</li>
    </ul>
    <b>安全性原则</b>
    <ul>
      <li style="margin-left: 2em;">计算安全性</li>
      <li style="margin-left: 2em;">可证明安全性</li>
      <li style="margin-left: 2em;">无条件安全性</li>
    </ul>
    <b>密码学分类</b>
    <ul>
      <li style="margin-left: 2em;">密码使用学</li>
      <li style="margin-left: 2em;">密码分析学</li>
    </ul>
    <el-divider></el-divider>

    <div class="bottom-container">
      <h3>在密码学中，对称加密和非对称加密的主要区别是什么？</h3>
      <el-radio-group v-model="radio">
        <el-radio :label="1">对称加密比非对称加密更安全。</el-radio>
        <el-radio :label="2">对称加密速度比非对称加密快。</el-radio>
        <el-radio :label="3">对称加密使用相同的密钥进行加密和解密，而非对称加密使用不同的密钥。</el-radio>
        <el-radio :label="4">对称加密和非对称加密没有区别。</el-radio>
        <el-button type="primary" plain :disabled="isButtonDisabled" @click="check(radio)">检查</el-button>
      </el-radio-group>
    </div>

    <el-divider></el-divider>

    <h3>1.6.2 密码使用学分类</h3>
    <ul>
      <li style="margin-left: 2em;">无秘钥算法</li>
      <li style="margin-left: 2em;">对称秘钥算法</li>
      <li style="margin-left: 2em;">公开秘钥算法</li>
    </ul>
    <el-image
        style="width: 970px; height: 500px"
        :src="require('@/assets/img/img2.png')">
    </el-image>
    <br>对称密钥算法双方共享一个密钥，并使用相同的加密和解密方法。<br>
    <el-image
        style="width: 959px; height: 256px"
        :src="require('@/assets/img/img3.png')">
    </el-image>
    <b>对称密钥算法</b>
    对称密钥算法重要术语：
    <br>
    明文：被传递的消息。用M表示，它可能是位序列、文本文件、位图、数字化的语音序列或数字化的视频图像等。对于计算机，M指的是二进制数据。
    <br>
    密文：加密后的消息。用C表示，对于计算机，C指的是二进制数据。
    <br>
    加密函数：作用于明文M得到密文C，用E表示。
    <br>
    数学公式：𝐶=𝐸(𝑀)
    <br>
    解密函数：作用于密文C还原明文M，用D表示。
    <br>
    数学公式：𝑀=𝐷(𝐶)
    <br>
    先加密后解密，原始明文将恢复：𝐷(𝐸(𝑀))=𝑀
    <br>
    <b>公开密钥算法</b>
    <br>
    公钥密码体制使用不同的加密密钥与解密密钥，是一种“由已知加密密钥推导出解密密钥在计算上是不可行的”密码体制。解密密钥是接收者专用的秘钥，对其他人都保密。
    <br>
    <el-image
        style="width: 955px; height: 343px"
        :src="require('@/assets/img/img4.png')">
    </el-image>
    <br>
    公开密钥算法重要术语：
    <br>
    发送者 A 用 B 的公钥 PKB 对明文 X 加密（E 运算）后，在接收者 B 用自己的私钥 SKB 解密（D 运算），即可恢复出明文：D{SK{B}}(Y)=D{SK{B}}(E{PK_B}(X))=X加密密钥是公开的，但不能用它来解密，即：D{PKB}(E{PK_B}(X))\neq X
    <br>
    <el-divider></el-divider>

    <div class="bottom-container">
      <h3>以下哪个选项描述了对称密钥算法的特点？</h3>
      <el-radio-group v-model="radio2">
        <el-radio :label="1">使用公钥和私钥进行加密和解密。</el-radio>
        <el-radio :label="2">加密速度比非对称加密算法更慢。</el-radio>
        <el-radio :label="3">加密和解密使用相同的密钥。</el-radio>
        <el-radio :label="4">密钥长度较短，易于管理和存储。</el-radio>
        <el-button type="primary" plain :disabled="isButtonDisabled2" @click="check2(radio2)">检查</el-button>
      </el-radio-group>
    </div>
    <el-divider></el-divider>
    <h3>1.6.3 密码分析学分类</h3>
    <el-image
        style="width: 918px; height: 550px"
        :src="require('@/assets/img/img5.png')">
    </el-image>
    <h3>古典密码学</h3>
    <b>古今密码学</b><br>
    密码学已经存在了几千年，密码学一词源于希腊语kryptós“隐藏的”，和gráphein“书写”。古典密码学的编码和破译通常依赖于设计者和敌手的创造力与技巧，作为一种实用性艺术存在，并没有对于密码学原理的清晰定义。而现代密码学则起源于20世纪末出现的大量相关理论，这些理论使得现代密码学成为了一种可以系统而严格地学习的科学。
    <br>
    <b>常见替换密码</b><br>单表替换加密法：明文中的同一字母在加密时被同一固定的字母代换。
    <ul>
      <li style="margin-left: 2em;">凯撒密码</li>
      <li style="margin-left: 2em;">简单替换密码</li>
      <li style="margin-left: 2em;">仿射密码</li>
      <li style="margin-left: 2em;">Polybius密码</li>
    </ul>
    多表替换加密法：明文中的同一字母在加密时不是完全被同一固定的字母代换，可能是多个。
    <br>
    <ul>
      <li style="margin-left: 2em;">维吉尼亚密码</li>
      <li style="margin-left: 2em;">ADFGVX密码</li>
      <li style="margin-left: 2em;">Enigma密码机</li>
    </ul>
    <h3>单表置换密码</h3>
    <b>凯撒密码</b>
    <br>恺撒密码（英语：Caesar cipher），或称恺撒加密、恺撒变换、变换加密，是一种最简单且最广为人知的加密技术。当年恺撒曾用此方法与其将军们进行联系。
    <br>现在已经无法弄清恺撒密码在当时有多大的效果，但是有理由相信它是安全的。因为恺撒大部分敌人都是目不识丁的，而其余的则可能将这些消息当作是某个未知的外语。即使有某个敌人获取了恺撒的加密信息，根据现有的记载，当时也没有任何技术能够解决这一最基本、最简单的替换密码。
    <br><b>算法：</b><br>
    明文中的所有字母都在字母表上向后（或向前）按照一个固定数目进行偏移后被替换成密文。𝐶=(𝑀+𝑘)𝑚𝑜𝑑26例如，当偏移量是3的时候，所有的字母A将被替换成D，B变成E，以此类推。
    <el-image
        style="width: 970px; height: 165px"
        :src="require('@/assets/img/img6.png')">
    </el-image>
    <br><b>破解凯撒密码</b><br>
    由于使用恺撒密码进行加密的语言一般都是字母文字系统，因此密码中可使用的偏移量也是有限的，因此可以通过穷举法，很轻易地进行破解。
    <br>密文：Q TQSM BW LZQVS UQTS明文：I LIKE TO DRINK MILK
    <br>
    <el-image
        style="width: 454px; height: 466px"
        :src="require('@/assets/img/img7.png')">
    </el-image>
    <br><b>小实验 </b><i class="header-icon el-icon-question"></i><br>
    破解一个凯撒密码密文：GR BRXO LNHF UBSWRJUDSKB
    <br>
    <a href="https://planetcalc.com/1434/" target="_blank">凯撒秘密在线分析网站</a>
    <el-divider></el-divider>

    <div class="bottom-container">
      <h3>密码分析学主要分为哪几个分类？</h3>
      <el-radio-group v-model="radio3">
        <el-radio :label="1">密码学攻击、密码破解、密码学防御、密码学应用</el-radio>
        <el-radio :label="2">密码学攻击、密码学防御、密码学应用、密码学原理</el-radio>
        <el-radio :label="3">密码学攻击、密码学防御、密码学原理、密码学应用</el-radio>
        <el-radio :label="4">密码学攻击、密码学研究、密码学实践、密码学应用</el-radio>
        <el-button type="primary" plain :disabled="isButtonDisabled3" @click="check3(radio3)">检查</el-button>
      </el-radio-group>
    </div>
    <el-divider></el-divider>

    <h3>1.6.4 简单替换密码</h3>
    将明文中所使用的字母替换为另一套字母表，形成新的对应关系。这种替换可以是任意的一对一关系。
    <br>
    例如：现有一个简单替换密码表
    <br>
    <el-image
        style="width: 787px; height: 93px"
        :src="require('@/assets/img/img8.png')">
    </el-image>
    <br>
    明文： crypto
    <br>
    密文： hzkrqb
    <br>
    简单替换密码很难通过穷举法来破译。密钥空间：26！=26×25×24×⋯×3×2×1
    <br>
    <b>破译简单替换密码</b>
    <br>已知一段密文：
    <br>UZQSOVUOHXMOPVGPOZPEVSGZWSZOPFPESXUDBMETSXAIZVUEPHZHMDZSHZOWSFPAPPDTSVPQUZWYMXUZUHSXEPYEPOPDZSZUFPOMBZWPFUPZHMDJUDTMOHMQ
    <br>有用信息：明文使用标准英文书写使用简单替换密码每个明文字母被唯一的密文字母替代
    <br>语言的每个字母都有其自身的特性，这是就像语言的指纹一样最容易观察出的特性就是字母出现的频率
    <br>
    <el-image
        style="width: 411px; height: 335px"
        :src="require('@/assets/img/img9.png')">
    </el-image>
    <ul>
      <li style="margin-left: 2em;">高频字母可以成为线索</li>
      <li style="margin-left: 2em;">低频字母可以成为线索</li>
      <li style="margin-left: 2em;">常见的字母组合可以成为线索（the , it , here , per 等）</li>
      <li style="margin-left: 2em;">密文越长越容易被破解</li>
      <li style="margin-left: 2em;">需要加入适当的猜测和推理</li>
    </ul>
    我们再次分析密文：
    <br>UZQSOVUOHXMOPVGPOZPEVSGZWSZOPFPESXUDBMETSXAIZVUEPHZHMDZSHZOWSFPAPPDTSVPQUZWYMXUZUHSXEPYEPOPDZSZUFPOMBZWPFUPZHMDJUDTMOHMQ
    <el-image
        style="width: 508px; height: 257px"
        :src="require('@/assets/img/img10.png')">
    </el-image>
    <ol>
      <li style="margin-left: 2em;">猜测P Z可能是e和t；</li>
      <li style="margin-left: 2em;">统计字母的相对频率-双字母</li>
      <li style="margin-left: 2em;">猜测ZW可能是th，因此ZWP可能是the</li>
      <li style="margin-left: 2em;">经过反复猜测、分析和处理，得到明文</li>
    </ol>
    it was disclosed yesterday that several informal but direct contacts have been made with political representatives of the viet cong in moscow
    <br>
    <a href="https://quipqiup.com/" target="_blank">在线进行词频分析网站</a>

    <el-divider></el-divider>

    <div class="bottom-container">
      <h3>简单替换密码属于哪种类型的密码算法？</h3>
      <el-radio-group v-model="radio4">
        <el-radio :label="1">非对称密钥算法</el-radio>
        <el-radio :label="2">散列函数算法</el-radio>
        <el-radio :label="3">对称密钥算法</el-radio>
        <el-radio :label="4">流密码算法</el-radio>
        <el-button type="primary" plain :disabled="isButtonDisabled4" @click="check4(radio4)">检查</el-button>
      </el-radio-group>
    </div>
    <el-divider></el-divider>

    <h3>1.6.5 仿射密码</h3>
    它的加密函数是$C=(aM+b) mod\space 26$，其中
    <ul>
      <li style="margin-left: 2em;">数字对（a，b）为密钥</li>
      <li style="margin-left: 2em;">a和26互素，既：$gcd⁡(a,26)=1$</li>
      <li style="margin-left: 2em;">b为小于26的正整数</li>
      <li style="margin-left: 2em;">在英文中有26个字母，因此是 $mod\space 26$</li>
    </ul>
    它的解密函数是$M=a^{−1} (C−b)mod\space 26$
    <br>
    解密函数，推导过程如下：
    \begin{gathered}C\equiv (aM+b)\space mod\space 26 \aM+b\equiv C\space mod\space 26 \M\equiv a^{−1}(C−b)\space mod\space 26\end{gathered}
    <br>
    $gcd⁡(a,26)=1$ 的原因：解密时需要求密钥参数a的逆元。如果a的逆元存在，则元素a与模数必须互素。
    <br><b>实例</b><br>
    字母A-Z对应的数字<br>
    <el-image
        style="width: 970px; height: 75px"
        :src="require('@/assets/img/img11.png')">
    </el-image>
    <br>加密若密钥对为（5，8），即函数中a为5，b为8，我们使用的是英文字母，即m为26<br>
    <el-image
        style="width: 970px; height: 136px"
        :src="require('@/assets/img/img12.png')">
    </el-image>
    <br><b>破解仿射密码</b>
    仿射密码和简单替换密码类似，最后都会形成一个明文字母和密文字母一对一的关系，然而区别在于，仿射密码的对应关系是由加密函数生成的，我们可以通过给定一个已知的明文攻击，求解出仿射方程式。
    <ul>
      <li style="margin-left: 2em;">通过对密文进行频率分析，确定两个替换关系，例如e被替换成了c，t被替换成了f</li>
      <li style="margin-left: 2em;">将字母转换成数字，模拟加密过程，求方程组：$2=(a×4+b)mod\space 26$【 e（对应数字4）被替换成c（对应数字2）的过程 】$5=(a×19+b)mod\space 26$【t（对应数字19）被替换成f（对应数字5）的过程</li>
      <li style="margin-left: 2em;">得到密钥对（21,22）</li>
    </ul>
    <b>小实验 </b><i class="header-icon el-icon-question"></i>
    <br>
    用仿射密码传送一个消息：offensive time tomorrow morning at ten o’clock密钥对为（7,10）
    <el-divider></el-divider>

    <div class="bottom-container">
      <h3>在仿射密码中，如果密钥对为（5，8），则加密函数中的参数 a 和 b 分别是什么？</h3>
      <el-radio-group v-model="radio5">
        <el-radio :label="1">a=3,b=8</el-radio>
        <el-radio :label="2">a=8,b=5</el-radio>
        <el-radio :label="3">a=5,b=8</el-radio>
        <el-radio :label="4">a=8,b=3</el-radio>
        <el-button type="primary" plain :disabled="isButtonDisabled5" @click="check5(radio5)">检查</el-button>
      </el-radio-group>
    </div>
    <el-divider></el-divider>

    <h3>1.6.6 Polybius密码</h3>
    这是一种简单的单码加密法，它将字母表的字母填充在一个正方形中，加上行列编号。
    <br>
    <el-image
        style="width: 388px; height: 387px"
        :src="require('@/assets/img/img13.png')">
    </el-image>
    <br>由于只有25个位置，所以去除字母j，因为 j 出现的频率低，用 i 来替代，不影响文字的可读性。明文中的a被替换成11，b被替换成12，依次类推。
    <el-divider></el-divider>

    <div class="bottom-container">
      <h3>在Polybius密码中，每个字母被加密为一个由两个数字组成的对应关系。如果密钥表格是一个 5x5 的方阵，那么加密时，密文字母对应的数字对是什么？</h3>
      <el-radio-group v-model="radio6">
        <el-radio :label="1">24, 12</el-radio>
        <el-radio :label="2">34, 23</el-radio>
        <el-radio :label="3">42, 51</el-radio>
        <el-radio :label="4">21, 45</el-radio>
        <el-button type="primary" plain :disabled="isButtonDisabled6" @click="check6(radio6)">检查</el-button>
      </el-radio-group>
    </div>
    <el-divider></el-divider>

    <h3>1.6.7 摩尔斯电码</h3>
    <el-image
        style="width: 936px; height: 483px"
        :src="require('@/assets/img/img14.png')">
    </el-image>

    <h3>1.6.8 PIGPEN密码（猪圈密码）</h3>
    <el-image
        style="width: 970px; height: 313px"
        :src="require('@/assets/img/img15.png')">
    </el-image>

    <h3>1.6.8 跳舞小人</h3>
    <el-image
        style="width: 860px; height: 488px"
        :src="require('@/assets/img/img16.png')">
    </el-image>

    <h3>1.6.8 培根密码</h3>
    由法兰西斯·培根发明的一种隐写术。
    <br>第一步：加密时，明文中的每个字母都会转换成一组五个英文字母。其转换依靠下表：<br>
    <el-image
        style="width: 527px; height: 189px"
        :src="require('@/assets/img/img17.png')">
    </el-image>
    <br>第二步：加密者需使用两种不同字体。准备好一篇包含相同AB字数的假信息后，即两种字体分别代表A型和B型。然后假信息中的每个字母按字体来决定其代表“A”还是“B”。
    <br>例如：
    <br>密文：LOVE密钥：对应的转换表密码算法：普通字体为A，斜体为B密文载体：messages is in the words
    <br>第一步：ABABA ABBAB BAABB AABAA第二步：messages is in the words

    <h3>1.6.9 Hill密码</h3>
    希尔密码(Hill Cipher)是基于线性代数多重代换密码，由Lester S. Hill在1929年发明。每个字母转换成26进制数字：A=0, B=1, C=2…Z=25一串字母当成n维向量，跟一个n×n的矩阵相乘，再将得出的结果MOD26。
    <br>
    <el-image
        style="width: 621px; height: 544px"
        :src="require('@/assets/img/img18.png')">
    </el-image>
    <br>Hill密码的解密<br>
    <el-image
        style="width: 602px; height: 446px"
        :src="require('@/assets/img/img19.png')">
    </el-image>
    <br>Hill密码证明和求逆主要参考线性代数知识。
    <br>对于单表加密法，破译人员可以通过密文频率分析对密文进行破译，有些需要花费很大的耐心，有些则通过工具可以直接破解。总的来说，这种加密方法还是太过于脆弱，下一节 ，我们将使用更复杂的方法让频率分析法失效。
    <el-divider></el-divider>

    <h3>多表置换密码</h3>
    <h3>1.7.1 维吉尼亚密码</h3>
    维吉尼亚密码（又译维热纳尔密码）是使用一系列凯撒密码组成密码字母表的加密算法，属于多表密码的一种简单形式。
    <br>维吉尼亚密码以其简单易用而著称，同时初学者通常难以破解，因而又被称为“不可破译的密码”。这也让很多人使用维吉尼亚密码来加密的目的就是为了将其破解。
    <br>维吉尼亚密码以布莱斯·德·维吉尼亚的名字来命名，然而其真正的发明者是莱昂·巴蒂斯塔·阿尔伯蒂。而维吉尼亚则发明过一种更强大的自动密钥密码。
    <br>为了生成密码，需要使用表格法。这一表格包括了26行字母表，每一行都由前一行向左偏移一位得到。具体使用哪一行字母表进行编译，是基于密钥进行的，在过程中会不断地变换。
    <br>明文：ATTACKATDAWN密钥：LEMONLEMONLE密文：LXFOPVEFRNHR
    <br>
    <el-image
        style="width: 517px; height: 516px"
        :src="require('@/assets/img/img20.png')">
    </el-image>
    <br><b>破译维吉尼亚密码</b><br>
    对于维吉尼亚密码，直接的频率分析却并不适用。由于在维吉尼亚密码中，同一个字母可以被加密成不同的密文，因而简单的频率分析在这里并没有用。如右图所示，任意截取了一段英文文章，加密后频率分布趋向平滑。
    <el-image
        style="width: 647px; height: 598px"
        :src="require('@/assets/img/img21.png')">
    </el-image>
    <br>破译维吉尼亚密码的关键在于它的密钥是循环重复的。如果我们知道了密钥的长度，那密文就可以被看作是交织在一起的凯撒密码，而其中每一个都可以单独破解。
    <br>此时，我们可以使用IC测试（也可以称为一致性索引），IC是基于凹凸度量理念。
    <br>如果字母完全平滑分布，说明密文中每个字母出现的概率相同，都为1/26。然而标准英文中字母频率分布不是平滑的，因此，凹凸度量是密文中字母实际频率与完全平滑频率（1/26）之差。
    <br>
    <el-image
        style="width: 970px; height: 184px"
        :src="require('@/assets/img/img22.png')">
    </el-image>
    <br>若选取的字母为：𝛼，出现频率为p_𝛼，密文总字数为n，𝑓𝛼是密文中字母𝛼的个数MR为完全偏差，a~z所有字母的偏差的平方和为：
    <br>MR=\sum{\alpha =a}^z(p\alpha -\frac{1}{26})^2
    <br>进行一定的取舍计算后得到：
    <br>MP=\sum{\alpha =a}^zp\alpha ^2 -0.038
    <br>IC的定义：
    <br>IC=\frac{\sum{\alpha =a}^z f\alpha (f_\alpha -1)}{n(n-1)}
    <br>单码加密法的IC值大概为0.066，对于完全平滑文字，其值为0.038，如果IC值位于0.038与0.066之间，说明加密的密钥长度不同。不同长度的密钥对应不同的IC值。
    <br>
    <el-image
        style="width: 782px; height: 286px"
        :src="require('@/assets/img/img23.png')">
    </el-image>
    <br>如果明文中的字母组合重复出现，被关键字加密后，密文也可能包含重复的字母组合，并且间距是密钥长度倍数。有一段密文如下：
    <br>DYDUXRMHTVDVNQDQNWDYDUXRMHARTJGWNQD
    <ul>
      <li style="margin-left: 2em;">两个DYDUXRMH的出现相隔了18个字母，则密钥的长度是18的约数</li>
      <li style="margin-left: 2em;">两个NQD相距20个字母，则密钥长度是20的约数</li>
      <li style="margin-left: 2em;">最大公约数是2，则基本可以判断密钥长度为2</li>
    </ul>
    <a href="https://planetcalc.com/2468/" target="_blank">维吉尼亚在线解密网站</a>
    <el-divider></el-divider>

    <h3>1.7.2 DFGVX 密码</h3>
    ADFGVX密码是德军在第一次世界大战中使用的栏块密码。事实上，它是早先一种密码 ADFGX 的增补版。1918年3月Fritz Nebel上校
    <br>发明了这种密码，并提倡使用。它结合了改良过的Polybius方格替代密码与单行换位密码。这个密码以使用于密文当中六个字母 A, D, F, G,
    <br> V, X命名。ADFGVX 是被法国陆军中尉 Georges Painvin 所破解的。以古典密码学的标准来说，此密码破解的工作是属于格外困难的，
    <br>在这期间，Painvin 更因此健康蒙受了严重损伤。他破解的方法是依靠于找到多份开头相同的讯息，这表示说它们是被相同的分解钥匙和移位钥匙加密的。
    <br><b>加密方式：</b><br>
    第一步：替换
    <br>将25个字母（ i / j 视为同一字母）任意填充至方格的灰色区域，不能重复或缺少，用字母所在的行列字母替代原有字母。如b为AA，g为GA
    <br>
    <el-image
        style="width: 478px; height: 279px"
        :src="require('@/assets/img/img24.png')">
    </el-image>
    <br>第二步：排列假设我们需要发送明文讯息 “Attack at once”替换后的密文为：AFADADAFGFDXAFADDFFXGFXF将得到的密文按密钥的长度进行排列：
    <br>
    <el-image
        style="width: 285px; height: 247px"
        :src="require('@/assets/img/img25.png')">
    </el-image>
    <br>第三步：移动
    <br>
    <el-image
        style="width: 285px; height: 247px"
        :src="require('@/assets/img/img26.png')">
    </el-image>
    <br>A:FAXDFC:ADDDGG:DGFFFO:AFAXXR:AFAFX
    <br>最终得到：FAXDF ADDDG DGFFF AFAXX AFAFX
    <el-divider></el-divider>

    <h3>1.7.3 ENIGMA密码机</h3>
    恩尼格玛密码机在1920年代早期开始被用于商业，一些国家的军队与政府也曾使用过它，其中的主要使用者是第二次世界大战时的纳粹德国。
    <br>
    <el-image
        style="width: 246px; height: 346px"
        :src="require('@/assets/img/img27.png')">
    </el-image>
    <br>
    <el-image
        style="width: 310px; height: 498px"
        :src="require('@/assets/img/img28.png')">
    </el-image>
    <br><b>ENIGMA密码机工作原理</b>
    <br>

    <el-image
        style="width: 779px; height: 372px"
        :src="require('@/assets/img/img29.png')">
    </el-image>
    <br>
    <ul>
      <li style="margin-left: 2em;">当键盘上的一个键被按下时，相应的密文在显示器上显示，然后转子的方向就自动地转动一个字母的位置（在示意图中就是转动1/6圈，而在实际中 转动1/26圈）。</li>
      <li style="margin-left: 2em;">相当于有26 个替换表的Vigenere加密。</li>
    </ul>
    <br>
    <el-image
        style="width: 423px; height: 598px"
        :src="require('@/assets/img/img30.png')">
    </el-image>
    <br>为了解决转子转动一圈重复的问题，密码机多增加了几个转子<br>
    <el-image
        style="width: 896px; height: 274px"
        :src="require('@/assets/img/img31.png')">
    </el-image>
    <ul>
      <li style="margin-left: 2em;">ENIGMA里有三个转子不重复的方向个数达到262626 =17576个。</li>
      <li style="margin-left: 2em;">相当于有17576个替换表的Vigenere密码。</li>
    </ul>
    <b>ENIGMA密码机反射器</b>
    <br>ENIGMA密码机反射器的加密与解密过程相同
    <ul>
      <li style="margin-left: 2em;">反射器和 转子一样，把某一个字母连在另一个字母上，但是它并不转动。</li>
      <li style="margin-left: 2em;">反射器可以使译码的过程和编码的过程完全一 样。</li>
      <li style="margin-left: 2em;">反射器从不把输入映射成自身。</li>
    </ul>
    <el-image
        style="width: 436px; height: 264px"
        :src="require('@/assets/img/img32.png')">
    </el-image>
    <br>ENIGMA密码机连接板
    <br>从26个字母中取出6对进行交换，比如：A/J, S/O, T/D, B/W, K/F, U/Y
    <ul>
      <li style="margin-left: 2em;">选择12个字母的可能性：$26!(12!\times 14!)$。</li>
      <li style="margin-left: 2em;">12个字母组合交换的可能性：$(\frac{12!}{6!\times 6!})\times 6!\div 2$两者相乘，共计：$3.21\times 10^{17}$另外，三个转子本身还有 17576 种可能性，所以，表的个数约有$3.38\times 10^{17}$。</li>
    </ul>
    <el-image
        style="width: 437px; height: 349px"
        :src="require('@/assets/img/img33.png')">
    </el-image>
    <b>Enigma曾在13年时间里（1926-1939）被认为坚不可摧</b>
    <br><b>Enigma的密钥管理</b>
    <ul>
      <li style="margin-left: 2em;">算法公开
        <ul>
          <li style="margin-left: 2em;">连接板交换6对字符，如：A/L , P/R, T/D, B/W, K/F, O/Y</li>
          <li style="margin-left: 2em;">转子的顺序，比如： 2,3,1</li>
          <li style="margin-left: 2em;">转子的初始方向，如：Q-C-W</li>
        </ul>
      </li>
      <li style="margin-left: 2em;">密钥保密
        <ul>
          <li style="margin-left: 2em;">每月发送当月每天的密钥</li>
          <li style="margin-left: 2em;">每条密文使用不同的密钥</li>
          <li style="margin-left: 2em;">每条电文的开头是加密的临时密钥，由三个字母重复两次加密而成, 称为indicator</li>
        </ul>
      </li>
    </ul>
    <el-image
        style="width: 917px; height: 275px"
        :src="require('@/assets/img/img34.png')">
    </el-image>
    <br><b>Enigma的破译：波兰人</b><br>
    <ul>
      <li style="margin-left: 2em;">可证明对于任何的连线变化都不影响循环圈的个数和每个循环圈上字母的个数；</li>
      <li style="margin-left: 2em;">尝试所有3 个rotors的初始位置，可以得到所有密钥的”fingerprint”，即循环圈的个数、每个循环圈上字母的个数:</li>
      <li style="margin-left: 2em;">需要操作的次数：26 26 26 ＝17576</li>
      <li style="margin-left: 2em;">考虑3个转子交换顺序3!，用6台Enigma协作运算</li>
      <li style="margin-left: 2em;">建立这样一个档案（book of fingerprints）用了一年时间</li>
      <li style="margin-left: 2em;">1938年, 德国人提升了密码强度</li>
      <li style="margin-left: 2em;">Enigma密码机另外增加了2个转子: 543 = 60</li>
      <li style="margin-left: 2em;">连接板交换6对字符提升至10对字符</li>
      <li style="margin-left: 2em;">波兰人没有足够经费造出足够多的Enigma密码机</li>
      <li style="margin-left: 2em;">德国人汉斯-提罗·施密特停止提供情报和密码本</li>
      <li style="margin-left: 2em;">1939年4月, 德国撕毁与波兰签订的和平协定，波兰处于战争乌云阴影之中。</li>
      <li style="margin-left: 2em;">1939年7月, 波兰人将破译成果展示给英法同行</li>
      <li style="margin-left: 2em;">1939年9月, 希特勒下令闪电战入侵波兰，波兰亡国</li>
    </ul>
    <b>Enigma的破译：布莱切利公园</b><br>
    破译小组于1939年在布莱切利公园组建，其中的成员包括：
    <ul>
      <li style="margin-left: 2em;">填字游戏爱好者</li>
      <li style="margin-left: 2em;">国际象棋专家</li>
      <li style="margin-left: 2em;">语言学家</li>
      <li style="margin-left: 2em;">数学家</li>
      <li style="margin-left: 2em;">电脑科学家</li>
    </ul>
    <b>Enigma的弱点</b>
    <ul>
      <li style="margin-left: 2em;">过于简单的密钥：比如DFG</li>
      <li style="margin-left: 2em;">重复使用的密钥：比如，CIL (cillie), -> silly</li>
      <li style="margin-left: 2em;">已知明文攻击(Know plaintext)，候选单词（crib）
        <ul>
          <li style="margin-left: 2em;">weather report</li>
          <li style="margin-left: 2em;">Heil Hitler</li>
          <li style="margin-left: 2em;">Nothing to report</li>
          <li style="margin-left: 2em;">Seeding, to get cribs</li>
        </ul>
      </li>
      <li style="margin-left: 2em;">明文中的同一个字母在密码中几乎可以变成任意的其它字母，但就是无法成为它本身。</li>
      <li style="margin-left: 2em;">过分严格的规定
        <ul>
          <li style="margin-left: 2em;">转子的位置不得重复： 如对3个rotor位置, 不是6 ，而是 2</li>
          <li style="margin-left: 2em;">连接板上的相邻的字符不得链接</li>
        </ul>
      </li>
      <li style="margin-left: 2em;">其他手段：盟军可以通过间谍偷取密码本</li>
    </ul>
    <b>Enigma的破译：图灵的方法</b>
    <ul>
      <li style="margin-left: 2em;">Alan Turing(1912-1954)
        <ul>
          <li style="margin-left: 2em;">1931年进入剑桥大学，提出图灵机模型</li>
          <li style="margin-left: 2em;">1933年受聘于GCCS，1939进入布莱切利公园</li>
        </ul>
      </li>
      <li style="margin-left: 2em;">图灵认为：波兰的方法依赖密钥的重复，如果德军改变密钥规则怎么办？</li>
      <li style="margin-left: 2em;">图灵的方法在候选单词的明文和密文之间找到字母循环圈的特征指纹</li>
      <li style="margin-left: 2em;">根据Enigma的弱点，明文中的同一个字母在密码中几乎可以变成任意的其它字母，但就是无法成为它本身。因此在破译时，我们可以确定：A 绝对不会是 A，B 绝对不会是 B …</li>
      <li style="margin-left: 2em;">利用这个漏洞，破译者可以先尝试猜测一个可能会出现在密码中的词语或短语，比如德语 “Heil Hitler”（希特勒万岁），然后把这个词语放在密文中任意的位置上，与整段密码进行比对，如果发现有重合的字母，那就说明该词语与当前的位置不匹配，一旦找到了一个没有重复字母的位置，那么很有可能那段密码所对应的明文正是 “Heil Hitler”。</li>
      <li style="margin-left: 2em;">在确定了至少一组正确的对应字母的前提下，破译者便可以通过假设和推理的方法猜测出一些可能的接线板上的字母配对。由于接线板上的一条接线会将两个字母绑定在一起，因此，如果我们猜测 A 接 B ，而由此却推导出了 C 接 A 的话，那么 A 接 B 的方案就是错的，而且由 A 接 B 所推导出来的一切可能的方案也全部都是错的；当接线板上，一个字母与所有其它字母的配对都被否决后，就说明问题出在转子上。这时，破译者要么更换转子，要么变动转子的位置，要么设定新的转子起始位置，再继续排查下去 … 这就是破译 “恩尼格玛” 的通用方法。</li>
      <li style="margin-left: 2em;">由于人力操作需要耗费大量的时间，英国数学家艾伦·图灵专门设计制造了一台 “炸弹机”（Bombe），通过电子技术，运用上述的排除法来破译 “恩尼格玛”，最快的一次仅用了大约20分钟。</li>
    </ul>
    <b>小结</b>
    多表替换加密都具有这样的特征：一个明文字母可映射到多个密文字母，这种加密可以干扰字母频率分析法，通常来说，多表替换密码肯定比单表密码更加安全。尽管加密的方法看上去十分复杂，这并不意味着它就是安全的，解密者会通过多种方式来寻找加密方法的线索，社会工程学就是他们必要技能，他们会想尽一切办法去破译密码。
    <el-divider></el-divider>
  </div>
</template>

<style scoped>

</style>